草庐IT

python - 列的 Django 数据库级别默认值

全部标签

sql - Rails 中独立于数据库的 SQL 字符串连接

我想在Rails查询中进行数据库端字符串连接,并以独立于数据库的方式进行。SQL-92指定双杠(||)作为连接运算符。不幸的是,MSSQLServer似乎不支持它;它使用+代替。我猜Rails的SQL语法抽象已经解决了特定于数据库的运算符问题。如果它确实存在,我该如何使用它? 最佳答案 我遇到了同样的问题,但从未想出任何内置于Rails中的东西。所以我写了这个小方法。#Symbolsshouldbeusedforfieldnames,everythingelsewillbequotedasastringdefdb_concat(*a

ruby-on-rails - rails 中是否内置了对默认值替换习惯用法的支持?

我经常编写代码以在遇到nil/空值时提供默认值。例如:category=order.category||"Any"#ORcategory=order.category.empty??"Any":order.category我即将扩展try方法来处理这个习语。category=order.try(:category,:on_nill=>"Any")#ORcategory=order.try(:category,:on_empty=>"Any")我想知道Rails/Ruby是否有一些方法来处理这个习惯用法?注意:我正在尝试消除||的重复/或/?基于运算符的习语。本质上,我正在寻找与try方

ruby - Python itertools 的 Ruby 等价物是什么,尤其是。组合/排列/groupby?

Python的itertools模块提供了很多关于使用生成器处理可迭代/迭代器的好东西。例如,permutations(range(3))-->012021102120201210combinations('ABCD',2)-->ABACADBCBDCD[list(g)fork,gingroupby('AAAABBBCCD')]-->AAAABBBCCDRuby中有哪些等价物?等效的,我的意思是快速和内存高效(Python的itertools模块是用C编写的)。 最佳答案 Array#permutation、Array#combin

ruby-on-rails - 如何在 Devise 中填充一些默认用户?

我正在尝试让Devise在我的Rails应用程序中运行。我是Rails的新用户。添加一些默认用户的正确方法是什么? 最佳答案 在Rails中设置任何默认数据的正常方法是在db/seeds.rb中添加数据:user1=User.create:name=>"User1",:email=>"user1@example.com",:password=>"user123"根据您的验证和设计功能,您可能需要输入更多字段。为了使用该数据,您只需调用rakedb:seed。rakedb:migraterakedb:seed

sql - 将每个 SQL 查询记录到 Rails 中的数据库

我想将某些SQL查询rails执行(即CREATE、UPDATE和DELETE)保存到日志文件中因此我需要拦截所有查询,然后可能使用一些正则表达式过滤它们并根据需要记录它们。我应该把这样的东西放在Rails代码的什么地方? 最佳答案 这里是c0r0ner链接的简化版本,以更好地展示它:connection=ActiveRecord::Base.connectionclasse;end#executeoriginalstatementoriginal_exec(sql,*name)endend

ruby-on-rails - 基于当前的托管服务,我应该将哪些数据库与 Ruby on Rails 一起使用?

我一直在寻找托管服务,但我仍然不知道哪种数据库最常见。好像是MySql和PostgreSql。所以,我不确定我的网站会有多少流量和数据(这只是一个项目),但我想做好准备。我曾在Oracle(PL/SQL)的一些项目中工作过,我对MySql有所了解。谢谢!附言。4年后,我主要使用PostgreSQL编写RoR。当我需要简单的应用程序时默认使用SQLite,否则使用PostgreSQL。 最佳答案 Rails的一个原则是你不应该真正关心你使用的是什么数据库:这些都是为你抽象的。所以我会说选择总体上最好的托管服务提供商,并相信他们会选择一

ruby-on-rails - 如何使用 ActiveRecord 最好地处理每个模型的数据库连接?

我想要规范的方式来做到这一点。我的Google搜索没有结果。我有一个ActiveRecord模型,它应该映射到与应用程序其余部分不同的数据库。我也想将新配置存储在database.yml文件中。我知道应该调用establish_connection,但不清楚在哪里。这是我到目前为止所得到的,但它不起作用:classFoo 最佳答案 此外,将使用不同数据库的模型子类化是个好主意,例如:classAnotherBase在你的模型中classFoo当您需要添加访问同一个数据库的后续模型时,它很有用。

ruby-on-rails - Rails ActiveAdmin。如何设置默认值?

我有这样的代码:ActiveAdmin.registerPostdoformdo|f|f.inputs"PostDetails"dof.input:titlef.input:bodyf.input:published_at,:as=>DateTime.nowendf.actionsend我希望字段:published_at(即t.datetime)默认设置为当前日期和时间。我的例子不起作用。我怎样才能做到这一点? 最佳答案 是的。自己找到了答案。ActiveAdmin.registerPostdoformdo|f|f.object.

ruby-on-rails - Rails 3.0.x 是否可以默认使用 Thin?

我基本上为我的开发/测试环境中的每个应用程序运行瘦网络服务器。当我将Mongrel与Rails2.x一起使用时,我只需键入script/server即可运行我选择的网络服务器。但是对于Rails3,我每次都必须指定Thin。是否可以通过键入railss而不是railssthin让Thin在我的Rails应用程序上运行? 最佳答案 是的,这是可能的。railss命令在一天结束时的工作方式是通过Rack并让它选择服务器。默认情况下,Rack处理程序将尝试使用mongrel,如果找不到mongrel,它将使用webrick。我们所要做的就

ruby - 将 UTF-8 设置为 Ruby 1.9.3 的默认值

我正在使用Rails4和Ruby1.9.3我经常使用“奇怪”的字符,所以我必须在所有.rb文件的顶部声明UTF-8编码。有没有办法将UTF-8设置为Ruby1.9.3的默认编码?我尝试了所有答案,但是当运行rakedb:seed并创建一个属性包含非US-ASCII有效字符的对象时,我仍然收到此错误:`blockintrace_on':invalidbytesequenceinUS-ASCII(ArgumentError) 最佳答案 要更改源编码(即您实际编写的源代码所在的编码),您目前必须使用魔术注释:#encoding:utf-8